﻿Public Class xtf_ABMpais

    Dim ulg_row As DataRow
    Dim obj_Pais As cls_pais_ = Nothing

    Public Sub New()
        InitializeComponent()
        Cargarsiglafiscal_()
        AgregarValidaciones()
    End Sub

    Public Overrides Sub CargarObjetos()
        Cargarsiglafiscal_()
    End Sub

    Private Sub Cargarsiglafiscal_()
        Dim tmp_obj As Integer = 0
        tmp_obj = cbo_SiglaFiscal.EditValue

        Dim siglafiscal_ As New cls_siglafiscal_
        siglafiscal_.CargarTodos()
        cargarCombo(cbo_SiglaFiscal, siglafiscal_.Items)
        cbo_SiglaFiscal.EditValue = IIf(tmp_obj <> 0, tmp_obj, cbo_SiglaFiscal.EditValue)
    End Sub

    Public Shadows Sub Nuevo(ByRef listado As Form)
        Try
            frm_listado = listado
            Me.Text = CType(frm_listado, xtf_ListadoBase).lbl_modulo.Text & " - Nuevo"
            obj_Pais = New cls_Pais_
            btn_Registro.Enabled = False
            Me.Show()
        Catch ex As Exception
            'Dim frmError As New frm_ErrorManager(ex.Message)
        End Try
    End Sub

    Public Shadows Sub Modificar(ByRef Pais As cls_pais_, ByRef listado As Form, ByRef row As DataRow)
        If IsNothing(obj_Pais) Then
            obj_Pais = New cls_Pais_
        End If
        obj_Pais = Pais
        frm_listado = listado
        ulg_row = row : bbi_imprimir.Enabled = True

        Me.Text = CType(frm_listado, xtf_ListadoBase).lbl_modulo.Text & " - " & obj_Pais.ToString
        txt_ID.Text = obj_Pais.idPais
        txt_Nombre.Text = obj_Pais.nombre
        txt_Nombrecorto.Text = obj_Pais.nombrecorto
        txt_ExtencionInternet.Text = obj_Pais.extencioninternet
        'cbo_SiglaFiscal.EditValue = obj_Pais.idsiglafiscal
        btn_Registro.Enabled = True

        obj_Pais.siglafiscal = Nothing
        Me.Show()

    End Sub

    Public Overrides Function ComprobarDatos() As Boolean
        'If Not cbo_SiglaFiscal.Enabled Then
        '    ErrManagerShow("001004")
        '    Return False
        'End If
        If Not ControlarValidaciones() Then
            ErrManagerShow("000004", Me)
            Return False
        End If

        'REGISTROS DUPLICADOS----------------------------------------------------
        Dim col As New Collections.Generic.List(Of stc_campoValor)
        Dim comp1 As New stc_campoValor
        comp1.campo = "nombre"
        comp1.valor = txt_Nombre.Text
        col.Add(comp1)
        If ComprobarDuplicado("pais_", col, "idpais <> " & IIf(txt_ID.Text = "", 0, txt_ID.Text)) Then
            ErrManagerShow("000010", Me, " Dato: Nombre")
            Return False
        End If
        'REGISTROS DUPLICADOS----------------------------------------------------

        Return True
    End Function

    Public Shadows Sub btn_Guardar_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btn_Guardar.Click
        If ComprobarDatos() Then
            obj_Pais.nombre = txt_Nombre.Text
            obj_Pais.nombrecorto = txt_Nombrecorto.Text
            obj_Pais.extencioninternet = txt_ExtencionInternet.Text
            obj_Pais.idsiglafiscal = 0 'cbo_siglafiscal.editvalue 
            If txt_ID.Text = "" Then
                obj_Pais.Nuevo(True)
                If frm_listado.Visible Then
                    ulg_row = CType(frm_listado, xtf_LISTADOpais_).AgregarItem(obj_Pais)
                End If
                Modificar(obj_Pais, frm_listado, ulg_row)
            Else
                obj_Pais.Modificar()
                If frm_listado.Visible Then
                    CType(frm_listado, xtf_LISTADOpais_).ModificarItem(obj_Pais, ulg_row)
                End If
                Modificar(obj_Pais, frm_listado, ulg_row)
            End If
            flg_Modificado = False : btn_Guardar.Enabled = False : bbi_guardar.Enabled = False
        End If
    End Sub

    Private Sub btn_Registro_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btn_Registro.Click
        If Not IsNothing(obj_Pais.registro) Then
            Dim ABMRegistro As New xtf_ABMRegistro(obj_Pais.registro)
            If ABMRegistro.ShowDialog() = Windows.Forms.DialogResult.OK Then
                flg_Modificado = True
            End If
        End If
    End Sub


    Private Sub btn_Cerrar_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btn_Cerrar.Click
        If flg_Modificado Then
            bol_comprobarCerrado = False
            Select Case ErrManagerShow("000001", Me)
                Case Windows.Forms.DialogResult.Yes
                    If ComprobarDatos() Then
                        btn_Guardar_Click(Nothing, Nothing)
                    Else
                        Exit Sub
                    End If
                Case Windows.Forms.DialogResult.Cancel : bol_comprobarCerrado = True
                    Exit Sub
            End Select
        End If
        Me.Dispose()
    End Sub
End Class